# Homework 3 (5%) Due: 2:00 PM, Friday 14 Oct.

### **Automated Testbenches for Verification**

#### Overview

The purpose of this homework is to learn and practice making testbenches for functional validation of your RTL designs.

## **Your Current Designs**

So far in HW1 and HW2 you have produced the following designs:

- 1) HW1
  - a) Data Dependent Left Rotate: VHDL
  - b) Data Dependent Left Rotate: Verilog
  - c) Data Dependent Right Rotate: VHDL
  - d) Data Dependent Right Rotate: Verilog
- 2) HW2
  - a) CounterA: Verilog,
    b) CounterB: VHDL,
    c) Counts UP,
    d) Upon reset: sets its value to the FIRST digit of your N number
    e) CounterB: VHDL,
    e) Counts DOWN,
    f) Upon reset: sets its value to the LAST digit of your N number

In HW3 you will now be producing test benches for these designs. You will need to produce 4 test benches, one for each of the following:

HW1 (a), testbench written in VHDL
 HW1 (d), testbench written in Verilog
 HW2 (a) CounterA, testbench written in VHDL
 HW2 (b) CounterB, testbench written in Verilog

#### **Tasks**

- 1) Implement the above test-benches as described, using the languages as noted.
  - a) Remember to note if each file was made using Copilot or not, with a comment on the first line of each file.
    - i) This will not affect your grade.
  - b) The test-benches should be fully automated and test **all** functionality.
    - i) 'All functionality' means every combination of inputs and behaviors.
    - ii) For the counters, where the behavior depends on the N number, the test benches should be tailored to the correct values for your N number.
    - iii) You can either fully enumerate all behaviors in the test-bench file or import test cases from a CSV or TXT file
  - c) Ensure that the test-benches check the output for correctness at each step of execution, and print 'all tests passed' at the end of the simulation if all tests pass.
- 2) Using the test-benches, perform simulations and capture screenshots of the waveform output (zoom out to get all data in one screenshot)
- 3) Using the VHDL test-bench (1), is it possible to validate the Data Dependent Right Rotate from HW1 (d) which is written in Verilog? Explain.

# **Deliverables:**

- 1. Submit a zip file with
  - a. your Xilinx project(s) (including the VHDL and Verilog files), and:
  - b. A README explaining your project(s) and the tested behaviors, and:
  - c. A PDF file containing the screenshots and captions describing them. Include the answer to question (3) with any evidence if collected.